/*这是一个组件 用于实现左右滑动切换图片
1 slot
2 将滑动的方向返回到父组件
*/
<template>
  <view @touchstart="handleTouchStart" @touchend="handleTouchEnd">
    <slot></slot>
  </view>
</template>

<script>
export default {
  data() {
    return {
      //按下的时间
      startTime: 0,
      //按下的坐标
      startX: 0,
      startY: 0
    };
  },
  methods: {
    //按下屏幕触发
    handleTouchStart(event) {
      this.startTime = Date.now();
      this.startX = event.changedTouches[0].clientX;
      this.startY = event.changedTouches[0].clientY;
    },
    //离开屏幕触发
    handleTouchEnd(event) {
      const endTime = Date.now();
      const endX = event.changedTouches[0].clientX;
      const endY = event.changedTouches[0].clientY;

      //判断按下的时长
      if (endTime - this.startTime > 2000) {
        return;
      }

      //滑动的方向
      let direction = "";

      //判断用户滑动的距离(X轴和Y轴都需要判断)
      if (Math.abs(endX - this.startX) > 10 && Math.abs(endY-this.startY)<10) {
        direction = endX - this.startX > 0 ? "right" : "left";
      } else {
        return;
      }

      //将计算的方向信息传递给父组件
      this.$emit("swiperAction", { direction });
    }
  }
};
</script>

<style>
</style>